import React, {Component} from 'react'
import './app.css'
import Header from "./component/Header";
import List from "./component/List";
import Footer from "./component/Footer";

export default class App extends Component {

    state = {
        todos: [
            {id: '001', name: '吃饭', done: true},
            {id: '002', name: '睡觉', done: true},
            {id: '003', name: '打代码', done: false},
            {id: '004', name: '逛街', done: true},
        ]
    }

    addTodo = (todoObj) => {
        const {todos} = this.state;
        const newTodos = [todoObj, ...todos]
        this.setState({todos: newTodos})
    }

    updateTodo = (id, done) => {
        const {todos} = this.state;
        const newTodos = todos.map((todoObj) => {
            if (todoObj.id === id) {
                todoObj.done = done;
                return todoObj;
            } else {
                return todoObj;
            }
        })
        this.setState({todos: newTodos});
    }

    checkAllTodo = (done) => {
        const {todos} = this.state;
        const newTodos = todos.map((todoObj) => {
            return {...todoObj, done: done}
        })
        this.setState({todos: newTodos})
    }

    deleteTodo = (id) => {
        const newTodos = this.state.todos.filter((todoObj) => {
            return todoObj.id !== id;
        })
        this.setState({todos: newTodos})
    }

    clearAllDone = () => {
        const {todos} = this.state;
        const newTodos = todos.filter((todoObj) => {
            return !todoObj.done;
        })
        this.setState({todos: newTodos})
    }

    render() {
        const {todos} = this.state;
        return (
            <div className="todo-container">
                <div className="todo-wrap">
                    <Header addTodo={this.addTodo}/>
                    <List todos={todos} updateTodo={this.updateTodo} deleteTodo={this.deleteTodo}/>
                    <Footer todos={todos} checkAllTodo={this.checkAllTodo} clearAllDone={this.clearAllDone}/>
                </div>
            </div>
        )
    }
}

